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1.0 INTRODUCTION 

The SA1401 Controller consists of a microprocessor-based controller 
with on-board data separator logic, and is able to control a maximum of 
two Shugart SA1000 fixed disk drives. The SA1401 can be mounted on the 
SA1000 drive. 

Commands are issued to the controller over a bidirectional bus 
connected to the host computer. The data separator/"serdes" logic 
serializes bytes and converts to MFM data, and deserializes MFM data 
into 8-bit bytes. 

Due to the microprogrammed approach utilized in the controller, 
extensive diagnostic capabilities are implemented. This methodology 
increases fault isolation efficiency and reduces system down time. 
Error detection and correction will tolerate media imperfections up to 
4-bit burst errors. 

2.0 SA1401 Controller 

2.1 Features 

2.1.1 The capabilities supplied as standard with the SA1401 are listed 
below: 



OVERLAPPED SEEK 



AUTOMATIC SEEK 
AND VERIFY 



FAULT DETECTION 



In multiple drive configurations, 
the host can issue seeks to 
different drives without waiting 
for the first drive to complete 
its seek. 

A seek command is implied in every 
data transfer command (READ, 
WRITE, CHECK, etc.). If the heads 
are not positioned over the 
correct cylinder, a seek is 
initiated, and a cylinder verifi- 
cation is performed after the seek 
completes. 

Two classes of faults are flagged 
to improve error handling: 

* Controller faults 

* Disk faults 



AUTOMATIC HEAD 
AND CYLINDER 
SWITCHING 



DATA ERROR 
SENSING AND 
CORRECTION 



LOGICAL TO 
PHYSICAL DRIVE 
CORRELATION 



ON BOARD SECTOR 
BUFFER 



EFFICIENT HOST 

INTERFACE 

PROTOCOL 



SECTOR 
INTERLEAVE 



ODD PARITY 



FIXED SECTOR 
SIZE 

NUMBER OF 
DRIVES 



If during a multi-block data_ 
transfer the end of a track ls 
reached, the controller 
automatically switches to the next 
track. If the end of a cylinder 
is reached, the controller 
issues a seek and resumes the 
transfer . 

If a data error is detected during 
a disk data transfer, the 
controller indicates whether or 
not it is correctable. If 
correctable, either a pointer and 
mask can be requested by the host 
for applying the correction or the 
error can be automatically 
corrected . 

Logical unit numbers (LUN's) are 
independent of physical port 
numbers. All accesses specify 
LUN ' s . 

A sector buffer is provided on the 
controller to eliminate the 
possibility of data overruns 
during a data transfer. 

A bidirectional bus between the 
controller and host provides a 
simple yet efficient communication 
path. In addition, a high level 
command set permits effective 
command initiation. 

Sector interleaving is 
programmable with up to 16 way 
interleave. 

The 8 data bits on the interface 
bus can have odd parity. 
Depending on user preference, 
parity can be disabled. 

The sector size is fixed at 256 
bytes of data. 

The controller will connect to a 
maximum of two (2) SA1000 drives. 



2.2 System Configuration 

The controller and data separator comprise a single PCB that can be 
mounted onto the SA1000 drive. A maximum of two (2) drives may be 
connected as shown in Fig. 2.1. 

2.3 Theory of Operation 

Disk commands are issued to the SA1401 via the host bus following a 
defined protocol. The host initiates a command sequence by selecting 
the controller on the bus. If the controller is not busy, it requests 
command bytes from the host for task execution. (Command structure is 
described in Section 4.0). Depending on the type of command, the 
controller will request up to 10 bytes. Upon reception of the last 
command byte, the controller begins execution of the command. 

For the data transfer commands, a check is performed on the disk 
address and status flagged if it exceeds the drive limits. The data is 
stored in a sector buffer before transfer to the host or disk drive. 
This buffer eliminates any possibility of data overruns between the 
host and the disk. 

Upon completion of the command, the controller will send completion 
status to the host. (Further delineation of the completion status may 
be requested by issuing the appropriate sense commands.) 

Odd parity is generated by the SA1401 for all information that it puts 
on the I/O bus. If enabled, the SA1401 flags all information that it 
receives with bad parity. 

2.3.1 Electrical Interface 

The electrical interface to the SA1000 will conform to the requirements 
described in the SA1000 interface specification. The electrical 
interface to the SA1401 Host Bus is shown in Fig. 2.2. 
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3.0 SA1401 HOST BUS 

The SA1401 Host Bus is as a negative-logic, bidirectional 8-bit data 
bus utilizing odd parity. The electrical interface consists of an open 
collector bus terminated on each end by a 220/300 ohm resistor network. 
The controller regulates transfers across the bus which eliminates data 
overruns that could occur during data transfers. 

The term "asserted" means that the signal on the host bus is between 0V 
and 0.8V. The term "deasserted" means that the signal on the host bus 
is between 2.5V and 3.5V (Negative or Low True logic). 

3.1 Signal Definition 

3.1.1 Unidirectonal Signals Driven By Controller 

I/O Input/Output 

When asserted, the data on the bus 
is driven by the controller. When 
deasserted, the data on the bus is 
driven by the host adaptor. The 
host adaptor will use this line to 
enable its drivers onto the data bus. 

C/° Command/Data 

When asserted, the data transmitted 
across the bus will be the command 
bytes. When deasserted, the data 
will be the disk data bytes. 

BUSY This bit is asserted as a response 
to the SEL line from the host 
adapter and to indicate that the 
host bus is currently in use. 

MSG Message 

When asserted, indicates that the 
command is completed. This bit is 
always followed with the assertion of 
I/O, and the assertion of REQ. 

REQ Request 

This bit operates in conjunction with 
I/O, C/D, & MSG. When asserted and I/O 
is asserted, REQ will mean that the 
data on the host bus is driven by the 
controller. When asserted and I/O is 
deasserted, REQ will mean that the data 
is driven by the host adaptor (H/A) . 



I/O C/D MSG Meaning 

dad Get command from H/A 

d d d Get data from H/A 

add Send data to H/A 

a a d Send status byte to H/A 

a a a Command done to H/A 

a ■ asserted, d ■ deasserted 



3.1.2 Unidirectional Signals Driven By Host Adaptor 



ACK Acknowledge 

This bit is asserted as a response to 
REQ from the controller. The timing 
requirements on this signal with 
respect to the data is described in 
REQuest section. ACK must be returned 
for each REQ assertion. Once REQ has 
been asserted, the controller waits 
256us for ACK return before timing out. 

RST Reset 

When asserted, this bit forces the 
controller to the beginning of its 
microcode. Any error status request will 
result in invalid information after RST 
has been asserted. All signals to the 
drives are deasserted. RST must be 
asserted for a minimum of 250ns and a 
maximum of lOus. 

SEL Select 

When asserted, indicates the beginning 
of the command transaction. The H/A 
asserts SEL to gain the attention of 
the controller. A data bit on the host 
host bus must also be asserted during 
SEL time to determine which controller 
is selected. SEL must not be asserted on 
the host bus before the data bit. The 
controller will return BUSY within 
lus. After the assertion of BUSY, the 
H/A will deassert SEL within 500ns. 



3.1.3 Bidirectional Data 

DB(7-0,P) - Data lines 7 thru represent the eight 
data bits (DBO-lsb) . Parity is 
represented by P. The controller 
utilizes odd parity (the number of 
asserted bits on the host bus is always odd) . 



3.2 Theory of Operation 

Whenever the host adaptor has a command for the controller, it performs 
a selection sequence to gain the attention of the controller. The 
sequence is as follows: 

The host adaptor asserts SEL and DBO (controller address bit) on the 
host bus. It then waits for the controller to respond with BUSY. Upon 
reception of BUSY, the H/A deasserts SEL. The controller now has 
control of the host bus. 

After the controller asserts BUSY, it then asserts C/D (to indicate 
command mode transfer), and deasserts I/O (to indicate output from the 
host adaptor) to fetch the command bytes from the H/A. The command 
bytes are transferred over the host bus with the REQ/ACK handshake 
protocol until all command bytes are transferred to the controller. 
(The command byte fetch mode ends after the last REQ pulse from the 
controller is Reasserted. ) 

For data transfer, the controller deasserts the C/D line to indicate 
data mode. Depending on the command type (read/write disk) , the I/O 
bit on the host bus is asserted or deasserted by the controller, and 
the data is transferred (one byte at a time) with the same REQ/ACK 
handshake protocol. After all the data bytes have been transferred, a 
completion status is. placed on the data bus by the controller - C/D and 
I/O are asserted. REQ is asserted and the controller waits for ACK 
from the host adaptor. After the status byte transfer, the controller 
places zeros on the data bus and asserts C/D, I/O and MSG along with 
REQ to indicate to the host that the command is complete (this action 
can be used to generate an interrupt on the host system) . After the 
H/A responds with ACK, the controller deasserts REQ, BUSY and all other 
lines. This completes the command execution and the controller is now 
ready to be selected for the next command. 



3.2.1 



TIMING REQUIREMENTS FOR 
SELECTION 



CONTROLLER 



SEL 



BUSY 



DBO 



100 ns - 
max 



«-»* 



te* 



ljJS 



no time 
limit 



Note: SEL must be deasserted before the controller will assert REQ 



Rev. B 



3.2.2 



TIMING REQUIREMENTS FOR DATA TRANSFER 
(to host adapter -typical byte) 



/O 



C/D 



D B 



REQ 



ACK 




Data driven 
by controller 



500ns to 
first REQ 



j 256JUS 
max 



time limit 



Note 1: For Status Byte Transfer (I/O, C/D asserted and MSG 

deasserted); or Interrupt Byte Transfer (MSG, I/O, C/D 
asserted) , REQ is asserted 500ns (typical) after the 
assertion of any of the above bits. 

2: Data driven by the controller is stable 100ns min at the 
host adapter end before REQ is asserted, and 100ns min 
after REQ is deasserted. 



3.2.3 



TIMING REQUIREMENTS FOR DATA TRANSFER 



(from host adapter -one byte) 



I/O 



C/D 



O B 



REQ 



ACK 




Y — Data driven 
*«— host adapter 



500ns to 
first REQ 



time limit 



Note 1: Data driven by the host adapter is stable 50ns max at 

the host adapter end after ACK is asserted , and 50ns min 
after REQ is deasserted. 

2: For command mode transfers, SEL must be deasserted before 
ACK is asserted. This sequence follows the selection 
protocol. 



4 . COMMANDS 

An I/O request to a disk drive is performed by passing a command 
descriptor block (CDB) to the controller. The first byte of a CDB is 
the command class and opcode. The remaining bytes specify the drive 
logical unit number (LUN) , block address, control bytes, number of 
blocks to transfer or the destination device ID. The controller 
performs an implied seek and verify when required to access a block. 

Commands are categorized into three classes as indicated: 

Class - Non-data Transfer, Data Transfer and Status 

Commands 
Class 1 - Disk Copy Commands 
Class 2-6 - Reserved 
Class 7 - Diagnostic Commands 

The command descriptor blocks in Command Class and 7 are 6 bytes 
long, and those in Class 1 are 10 bytes long. 

Command Description (Class 0) 

Opcode Description 
(Hex) 

00 Test drive ready. Selects the drive and verifies drive 
ready. 

01 Recalibrate. Positions the R/W arm to TrackOO, clears 
possible error status in the drive. 

02 Request Syndrome. Returns the offset and syndrome for data 
field error correction. The two bytes are as follows: 



| M.S. BIT OFFSET (8) 



L.S. BIT OFFSET (3) I I SYNDROME (4) 



The bit offset is relative from the first data 
bit, i.e., Bit 7 of Byte 0. 

03 Request Sense. This command must be issued immediately after 
an error. It returns 4 bytes of drive and controller sense 
for the specified LUN (see copy block for exception). 

04 Format Drive.. Formats all blocks with ID field according to 
interleave factor and data fields. The data field contains 
E5 Hex . 



05 Check Track Format. Checks format on the specified track for 
correct ID and interleave. Does not read the data field. 

06 Format Track. Formats the specified track with bad block ^ 
flag cleared in all blocks of that track. Writes E5 Hex in 
the data fields. 

07 Format Bad Track (bad block flag). Formats the specified 
track with bad block flag set in the ID fields. Writes E5 
Hex in the data fields. 

08 Read. Reads the specified number of blocks starting from 
initial block address given in the CDB. 

0A Write. Writes the specified number of blocks starting from 
initial block address given in the CDB. 

OB Seek. Initiates seek to specified block and immediately 
returns completion status before the seek is complete for 
those drives capable of overlap seek. 



Command Description (Class7) 

Opcode Description 
(Hex) 

00 RAM Diagnostic. Performs a data pattern test on the RAM 
buffer. 

01 Write ECC. Displaces data on the disk by three bytes so that 
the ECC bytes can be written from the data specified. Used 
to verify the ECC logic. 

02 Read ID. Transfers the cylinder, head, sector and 3 ECC 
bytes for the specified block ID field. 

03 Drive Diagnostic 0. Performs a drive diagnostic. Reads 
Sector on all cylinders sequentially. Reads Sector on 
256 random cylinders. 



4.1 Command Format 

4.1.1 Class & 7 Commands 



Byte 

1 
2 



7 ! 6 


! 5 ! 4 ! 3 ! 2 ! 1 ! J 


or 


7 | opcode ! 


LUN 


} logical adr2** \ 


logical adrl** ! 


logical adrO** j 


number of blocks* j 




control field ! 



*Inter leave factor for Format, Check Track, and Read ID commands. 
**Refer to section 4.3 Logical Address. 

The control field is defined as follows: 



! 7 ! 6 J 5 | 4 « 3 ! 2 ! 1 i ! 



j spare (set to zero) 



disable overlap 

disable data error correction 

disable retry 



Commands in this group 



NOP 

Format Drive 

Check Format 

Request Sense 

Request Syndrome 

Recalibrate 

Read Block (s) 

Read ID 

Write Block (s) 

Format Track 

Format Track (bad track flag; 

Seek 

Ram Diagnostic 

Drive Diagnostic 

Write ECC 



4.1.2 Class 1 Commands 



Byte ! 


7 


1 6 ' 


5 ! 4 ! 3 ! 2 j l ! o ! 











1 j opcode ! 


1 




LUN/s 


! logical adr2/s* j 


2 


logical adrl/s* j 


3 


logical adrO/s* j 


4 


number of blocks | 


5 




LUN/d 


i logical adr2/d* | 


6 


logical adrl/d* j 


7 


logical adrO/d* j 


8 


spare j 


9 


[ control J 



"s™ ■ the source device, w d" a the destination device 
♦Refer to section 4„3 Logical Address 
Commands in this group: Copy Block 



4.2 Status Format 

4.2.1 Completion Status Byte 



|7J6J5!4!3!2!1|0! 



i < LUN > ! < — spare — > ! 



— Parity error 

— Error 



Parity error occurred during transfer from host to controller 

Bit 1 Error occurred during command execution. 

Bit 2-4 Spare (set to zero) . 

Bit 5-7 Logical unit number of the drive. 



4.2.2 Drive and Controller Sense Bytes 

The following bytes are returned from the controller for the Request 
Sense Command . 



Byte 



! 7 | 6 



! 5 ! 4 ! 3 ! 2 



! ! < — Error code-> 



Error type 

Spare (set to zero) 

Block address valid 



Byte 
1 
2 
3 



7 ! 6 


! 5 ! 4 ! 3 J 2 


! 1 ! 


LUN 


j logical 


adr2* 


logical adrl* 


logical adrO* 



**Refer to section 4.3 



4.3 Logical Address 

The logical address is computed as follows: 

Logical adr - (CYADR * HDCYL + HDADR) * SETRK + SEADR 

Where: CYADR = cylinder adr ess 
HDADR ■ head address 
SEADR = sector address 
HDCY ■ number of heads per cylinder 
SETRK = number of sectors per track 

Bit of Logical adrO = the least significant bit 
Bit 4 of Logical adr2 = the most significant bit. 



4.4 Error Code Descriptions 
4.4.1 Sense Command Results 

Type (Drive) Error codes. 

No status 

1 No Index signal 

2 No Seek Complete 

3 Write fault 

4 Drive not ready 

5 Drive not selected 

6 No TrackOO 

7 Multiple Drives selected 

Type 1 (Controller) Error codes. 

ID read error. ECC error in the ID field. 

1 Uncorrectable data error during a read. 

2 ID Address Mark not found. 

3 Data Address Mark not found. 

4 Record not found. Found correct cylinder and head but not 
sector . 

5 Seek error. R/W head positioned on a wrong cylinder and/or 
selected a wrong head. 

6 (Not used) . 

7 (Not applicable) . 

8 Correctable data field error. 

9 Bad block found. 

A Format Error. The controller detected that during the Check 
Track command, the format on the drive was not expected. 

Type 2 (Command) Error codes. 

Invalid Command received from the host. 

1 Illegal disk address. Address is beyond the maximum address. 

Type 3 (Misc) Error codes. 

RAM error. Data error detected during Sector buffer RAM 
diagnostic. 



8.5 


inches 


13.5 


inches 


0.49 


inches 


1.12 


lbs. 



5.0 ELECTRICAL/MECHANICAL SPECIFICATIONS 

Physical Parameters 

Width 
Length 
Height 
Weight 



Environmental Parameters 

Operating: Storage: 

Temper atureegree 
(degrees F/C) 32/0 to 131/55 -40/-10 to 167/75 

Relative Humidity 

(@ 40 degrees F, 

wet bulb temp. , 

no condensation) 10% to 95% 10% to 95% 

Altitude sea level to sea level to 

10K feet 15K feet 



Power Requirement 

Voltage @ current +5 VDC @ 4.6A (max) 

-5 VDC § 500 mA (max) 

+24 VDC § 100 mA (max) 



6.0 DIAGNOSTIC PHILOSOPHY 

6.1 Error Indicators 

The controller contains 8 diagnostic LED error indicators. Each time 
an error occurs the controller deposits a value in the LED's and 
returns a failure status to the host adaptor. The LED value can be 
decoded, but the error it indicates will always be available to the 
host software. The errors that are returned by the controller are very 
detailed. As a result, preliminary fault isolation is made fairly 
easily, narrowing the failure to the particular interface portion of 
the controller. In addition, two diagnostic commands can be invoked 
via the host software interface. One is the RAM Diagnostic Command, 
and the other is the Drive Diagnostic Command. 



6.2 Additional Microdiagnostics (Optional) 

The controller can be further checked out off-line by initiating # 
explicit microdiagnostic routines via optional firmware diagnostic 
sets. The routines are initiated by a set of control switches. Errors 
will be displayed in a set of LED's. Each microdiagnostic checks the 
functionality of a particular section of the controller and is able to 
isolate failures in the following major categories: 

ALU 

Registers 
Sector Buffer 
ECC Logic 

Fault-isolation techniques can be concentrated on the failing section. 



7.0 SA1000 SECTOR FORMAT 



The track layout for the SA1000 (typical for 3 2 sectors) is shown 
below. 



13 
bytes 
00's 



10 




13 
bytes 
00's 



256 
bytes 
data 



15 
bytes 
4E's 



am, FE, cyl, hd, sec, 00, F8 - 1 byte 
ecc = 3 bytes 

Track Capacity - 10416 + 3.5%, i.e. + 365 bytes 

10048 - 314 x 32 

16 - Index Gap (4E) 
352 - Speed Tolerance Gap (4E) 



10416 



314 bytes/sector 
Last Gap - 352 bytes 



Host I/O Connector Pin Assignment. 

The Host I/O Bus uses a 50-pin connector (AMP P/N 2-87227-5 or 
equivalent) . The unused signal pins are considered to be spares for 
future use. The pin assignments are as follows : 

Signal 

DATAO 
DATA1 
DATA 2 
DATA3 
DATA4 
DATA 5 
DATA 6 
DATA 7 
PARITY 



Pin 


Number 


2 




4 




6 




8 




10 




12 




14 




16 




18 




20 




22 


• 
i 


24 


i 
i 


26 


Future 


28 


Usage 


30 


i 
i 


32 


i 


34 




36 




38 




40 




42 




44 




46 




48 




50 





BUSY 

ACK 

RST 

TDN 

SEL 

C/D 

REQ 

I/O 



NOTE: All signals are negative true and all odd pins are connected to 
ground. The signal lines are terminated with 220 ohms to 5V and 330 
ohms to ground. 



APPENDIX A 

CUSTOMER FIRMWARE: DIP SWITCH SETUP PROCEDURE FOR THE SA1401 

Prom Set WS30 - I, II, III, IV 

Location : 2H 



Switch Bits 


8 


7 


6 5 


I 4 3 


2 1 




Field 
Definition 


LUN 
Drive 
Type 


LUN 1 
Drive 
Type 


1 LUN 2 
1 Drive 
1 Type 


LUN 3 
Drive 
Type 



F 
F 
1 


N 












2 heads, 
4 heads, 

1 




I 
1 


Drive 
Type 




1 
1 


Description 




1 
1 
1 
1 


0-on 
1-on 
2-off 
3-off 


on 
off 
on 
off 


I 
1 
1 
1 


SA1002 
SA1004 
reserved 
reserved 


256 
256 



all drives are 32 sectors/ track, 256 bytes/sector 



******************** 

* * 

* Example: * 

* * 

******************** 
Location: 3D 



1 8 7 


6 5 


4 3 


2 1 




1 LUN 
I Drive 
1 Type 

I on on 


LUN 1 
Drive 
Type 

on on 


LUN 2 
Drive 
Type 

on off 


LUN 3 
Drive 
Type 

on on 




F 
F 
1 


N 



Drive 0, 1, and 3 are set up for SA1002 
Drive 2 is set up for SA1004 



**************** 

* * 

* WARNING 1 * 

* * 

**************** 



The following voltages are required: 

a) +24VDC (Pin l)y +24V return is Pin 2 

b) +5VDC (Pin 5); +5V return is Pin 6 

c) -5VDC (Pin 4); -5V return is Pin 3 

DO NOT USE -15VDC ON THE SA1401 1 
SERIOUS DAMAGE WILL RESULT. READ THE 



SPECIFICATION BEFORE ATTEMPTING POWER ON I 



